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(54) Printing of hybrid images, including halftoning 



(57) To provide high-speed printing with an inexpen- 
sive arrangement, a dedicated printer control hardware 
circuit 5 is provided between a printer driver 1 of a host 
computer and a printer 9. The printer driver 1 divides an 
image to be printed into an illustration (a natural image), 
such as a photograph or a drawing, and charac- 
ters/graphics. The printer driver outputs full-color RGB 
raster data for the illustration, while performing color 
conversion/halftoning for the character/graphic data and 
outputting binary CMYK raster data. The control circuit 



5 performs color conversion/halftoning for the full-color 
illustration RGB raster data to convert them into binary 
CMYK raster data. Then, the control circuit 5 superim- 
poses the obtained binary CMYK raster data and the 
binary CMYK raster data for characters/graphics to form 
binary CMYK raster data for a complete print image, 
and transmits the final binary CMYK raster data to the 
printer 9. The control circuit 5 also rearranges or thins 
pixel data for interlace printing or overlap printing. 



FtG.1 



CM 
< 

in 

o> 
o 

CT> 



PRfTNER 
DRIVER 



13 

i 



COMMAND 

analysis/ 
path control 
circuit 



iL 



IS 



COLOR 
CCNVESSJOW 
HALFTONING 
ORCUIT 



17 
i 



SUPERM- 
POSffW 
NTERLAONO 
OUGHT 



4 {r— f 1 4 ? 

J ubiory / 

-M CONTROL H^- 
aRCUTT 



-45 



COMMAND * 
BUFFER 



BUFFER 



COMMAND 
GENERATION |— 23 
QRCUn* 



"EE 



21 



-25 



PRINTER -9 



QL 
LU 



Primed by Xerox (UK) Business Services 
2.16.7/36 



BNSCOCID: <EP 0940975A2_L> 



EP 0 940 975 A2 

Description 

BACKGROUND OF THE INVENTION 
1 . Field of the Invention 



[0001 ] The present invention relates to a printer control technique for high-speed printing 

as CMY £ cSXc e i!S2 6d V™*^ SyStemi 6tC - emp '° yS C0,0rin9 a9ents for a ,imited number * «*»■ such 
n vl « ' . ! ° r d06S n0t form Sma " individua 'V dots at locations on paper that correspond to 

p.xels (for some printer models, the sizes of dots are further changed at a plurality of levels) thereby pSng a 
pseudo-continuous tone .mage that appears, to the eyes of a viewer, to be a continuous tone nrage NomSTSi 
jmage data that are required by a primer are CMYK raster data that determine whether dots for (^cKK£2 

o a do is designated at one of a plurality of levels). Since the CMYK raster data have only two or slightly more fevete 
CM^sterUTa ^ C ° mp ° nentS ' h ** such raster data are called MciTSS 

[0003] Original image data, which are generated or are externally entered with an application used by a host computer 
that.ssues print commands toaprinter. are normally high-resolution RGB data. ^ 

££217 r ? era f r a pri ? er display color system - that ™ rgb «* * 32 

high resolution evels, such as 256 levels, are provided for the individual color components. The original image £ta may 

T7 } ^ represented as a 561 * P fxel ^ or they may be highi data tat . e 
resented by a graphic function or character codes. ^ 

2. Description of the Related Art 

[0004] In a conventional printing system, a printer driver, which is software that is provided for a host computer or 

3i.u2 a CMYl;t; a Tff 3 ^ C ° merte hi9h - resolution RGB *» * - origina, imaged fina 
SL ? OTnv * s,on pr0C6SS ,ncludes "^terization." for converting high-level original image 

data to raster data, color conversion," for employing a lookup table to convert RGB pixel values to CMY or CMYK pixel 

£n ° r dftherin9 10 W^on pixel vSues toioTeS 

2 va,ues ; F °l an ,nk -JfP" n te r . order to improve the image quality a so-called "interlaced" printing method or 

ordeT^e^^ d0,S " form&d h a " 0reler differin9 from *• »*d 

order. The rearrangement of pxels is also performed during the above conversion process 

[0005] The above described conversion process constitutes a large load for the CPU of a host computer when the 
process -s controlled using the printer driver, or for the CPU of a printer when control is provided by^TprinteT There 
fore, an extended period of time is required for this processing; it is the major factor affecting the printing ieed ir ™*der 

to ^iT'^r^ hi9h - SP6ed and CPU is mounted in a printer.such aVTtaVer pVZ 

to perform ttie above descnbed conversion process at the printer. However, as a result We price of the laser printer is 
quite high^ On ^contrary, with an ink-jet printer, in order to reduce the price of the printer. the above iSITSoc 
^ H% 1 3 • Pr J nter driVer 8t 3 *** COmputer that controls entire P roce ss- But in this case, the printing 

TT ' - ,6t 1 ^ iS fair ' y S,0W ' 3nd *• ,en9th °' *« •» host «»W is occupied is so fong 
that other jobs can not be performed on the host side. h ~ .a long 

SUMMARY OF THE INVENTION 

is Quired" 6 ° bieCtiVe * ** PreS6nt inVenti ° n ,S 40 PrOVid6 hi9h - speed P rintin 9 for which only inexpensive equipment 
. A " ot |; er ° bjective of tne P resent Mention is to provide high-speed printing without imposing a large load on 
ernpfoyed 3 environment wnerein a ^Peed printer, such as a conventional ink-jet printer, is 

pr!Sg *" additi ° nal ° bjeCtive * the pr6Sent invention is toP™idean inexpensive printer that can perform high-speed 

[0009] According to the present invention, a dedicated printer control hardware circuit is provided between an upper 
apparatus, such as a host computer, and a printer. The dedicated hardware circuit may be incorporated in the upper 
apparatus or ,n the printer, or may be externally attached to these two. The dedicated hardware circuit receives from Sie 
upper apparatus high-resolution raster data for the first image element and low-resolution raster data for the second 
image element, performs a halftoning process for the high-resolution raster data of the first element to convert them into 
low-resolution raster data, employs the obtained low-resolution raster data and the low-resolution raster data for the 
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second element to acquire low-resolution raster data for a complete print image, and transmits to a printer the low-res- 
olution raster data that is finally obtained. 

[001 0] According to the present invention, since the dedicated hardware circuit performs the halftoning process for 
the first image element and generates a complete image, the upper apparatus does not need to perform the halftoning 
5 process for the first image element, and since the printer does not need to perform any halftoning process, high-speed 
printing is ensured. As the dedicated hardware circuit is provided using an ASIC (Application Specified IC), it costs less 
than a conventional high-speed printing system in which a fast CPU is mounted. 

[001 1 ] In the preferred embodiment, the first image element is an illustration (a natural image), such as a photograph 
or a drawing, and the second image element is a character or a graphic. As for an illustration, high-resolution raster data 

w of the display color type for the upper apparatus (e.g. , full color RGB raster data) are transmitted from the upper appa- 
ratus to the dedicated hardware circuit. A color conversion and halftoning process is performed for the raster data by 
the dedicated hardware circuit to change them into low-resolution raster data of the printer color display type (e.g., 
binary CMYK raster data). As for characters and graphics, low-resolution raster data of the printer display color type 
(e.g., binary or multilevel color RGB raster data) are transmitted from the upper apparatus to the dedicated hardware 

is circuit. In this embodiment, since the upper apparatus (specifically a host computer) need only perform color conversion 
and halftoning for characters or for graphics, which is a comparatively light-load process, and since the dedicated hard- 
ware circuit performs color conversion and halftoning for an illustration, which is a comparatively heavy-load process, 
high-speed printing is ensured. Generally, high resolution is required for an illustration in order to obtain a clear outline 
for a character or a graphic. In this embodiment, however, since the data for characters and for graphics are converted 

20 into low-resolution raster data by the upper apparatus, and the obtained raster data are transmitted to the dedicated 
hardware circuit, the quantity of data to be transmitted is not increased even though the data have a high resolution, 
and this fact also contributes to high-speed printing. 

[001 2J In addition, in the preferred embodiment, since for interlaced printing the dedicated hardware circuit changes 
the pixel order, this also contributes to high-speed printing. 

25 [0013] Furthermore, in the preferred embodiment, the dedicated hardware circuit includes a memory, and writes 
therein the memory raster data for an illustration and the raster data for a character or a graphic, while at the same time 
superimposing these data, so as to provide raster data for a complete print image in the memory. Since the memory is 
employed in this manner, only a simple structure is required for the superimposition of the illustration and the charac- 
ters/graphics, and this contributes to a reduction in the price. 

30 [0014] Further, since the writing either of the illustration data or of the character/graphic data is performed while the 
other data are being written, a common circuit can be used to write illustration data and character/graphic data, and this 
also contributes to a reduction in the price. 

[001 5] Moreover, in the preferred embodiment, the upper apparatus sequentially transmits, for each raster, raster data 
for an illustration and raster data for characters/graphics. When the dedicated hardware circuit ascertains that the end 
35 of the raster has been reached, both for the illustration and for the characters/graphics, it increments a vertical address 
to designate a location in the memory at which to write the raster. Therefore, a simpler circuit is provided for the super- 
imposing and the writing of the photo raster data and the character/graphic raster data for the same raster, and this also 
contributes to a reduction in the price. 

[0016] In the preferred embodiment, as for a raster where an illustration or characters/graphics do not exist, a raster 
40 end command is transmitted from the upper apparatus to designate the end of the raster, even for an image element 
that does not exist in the raster. Therefore, upon receiving the raster end command, the dedicated hardware circuit can 
identify the end of the raster for the image element that does not exist and can increment the vertical address. As a 
result, for the image element that does not exist, the writing of null data to the memory can be performed without the 
actual writing being carried out, and this can also contribute to high-speed processing. 
45 [001 7] In the preferred embodiment, the memory in the dedicated hardware circuit is employed as a ring buffer. While 
the print head of the printer is reading raster data from the memory for a raster that is required for the current path (the 
main scanning), raster data are written in the memory up to the last raster that the print head requires for the next path. 
The storage capacity provided for the storing of raster data in a memory can be the smallest that is needed for the stor- 
age of an amount of raster data that is equivalent to the data available in a range wherein the print head covers two 
so paths. This also contributes to a reduction in cost. 

BRIEF DESCRIPTION OF THE DRAWINGS 



[0018] 



£5 



Fig. 
Fig. 
Fig- 



1 is a diagram illustrating the general arrangement for one embodiment of the present invention. 

2 is a diagram showing a variation for the location of a dedicated printer control circuit (control circuit) 5. 

3 is a diagram showing the structure of illustration CMYK raster data. 



3 



BNSDOCIDkEP 0940975A2 I > 



• 



EP 0 940 975 A2 

Fig. 4 is a diagram showing the structure of character/graphic CMYK raster data. 

Fig ? is a diagram showing the circuit arrangement of a superimposing/interlacing circuit for writing CMYK raster 
aata in a memory. " 

Rg. 6 is a diagram illustrating the arrangement of an address determination circuit in Fig 5 
Fig. 7 a diagram showing color planes in a memory. 
Fig. 8 is a diagram showing rasters printed at individual paths. 
Rg. 9 is a diagram showing the writing/reading of raster data from a memory. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 

SHInl I ShOWS the 9eneral ^^^^ according to one embodiment of the present invention. 
[0020] A dedicated printer control hardware circuit (hereinafter referred to as a control circuit) 5 is located between a 
pnnter dnver 1 , wh,ch is software that is stored in a host computer, and a printer 9. The control circurt 5 is a hSare 
logic arcurt composed, for example, of an ASIC (Application Specified IC). and is not a computer with a CPUto^l 
cuting software. The control arcuit 5 receives a control circuit command 3 from the printer driver 1. and prepared 
printer command 7 for the printer 9 and transmits it thereto. 

[0S>1] In Fig. 2, three variations are shown for the location of the control circuit 5: a block 33 in Fig. 2. where the cen- 
tre ^'t5*,ncorpo^ 

it* axternal.y attached to *e computer 31 and the pnnter 9. The host-incorporated control circuit 5 is provides a 
host computer option board, which ,s connected to the internal bus of the host computer 31 and to the printer 9 by for 
example a parallel .menace cable (or across a communication network). This type can cope with a plurality of printers 
The unincorporated control arcurt 5 is provided as a printer option board, which is connected to the InTernS bus of 
* P "T-l ' S connected to tne nost 31 by. for example, a parallel interface cable (or a communication 

ZSSt ^Tl T COPe . Wit S, a S ra,ity ° f h ° St C ° mpUterS - M the externally-attached eoLf STXtS 
nSwfrkt ^ Printer 9 ^ eXamP ' e ' 8 Para " 61 int6rfaCe CaWe (0r Via 8 w™"*^ 

STSL Ge " era ^ f ima9 x e „ , ° be P rinted is **** ir *o th"* different types of print data: "character." "graphic." and 
c^f 2 Sr?- ™ e " chara *er" *»" are characters or symbols that can be represented using characS 
St'^inn ^ draWin9S ° r 9e ° metriC images can be resented using a function, ni 

i ITL i ■ P Tf ' I m \ m T- ^^"y- a Photograph or a picture, that is represented using raster data 
n±r T J 1 1 • J 13 ' 1 , , When the printer driver 1 receives ori 9 inal ima °e data from the OS of the host corn: 
2S£ETT ^ ° m the ° ri9inal imagS date ' Separate data for characters/graphics and dXSr a 
natural mage, and performs "rasterization." "color conversion" and "halftoning" for the character/graphic data changing 

mine ^^S^TJtT^ 1 * "Z? V* °** ^ < s P ecif CMYK raster Sata used to deter 
STh^lT ♦ ^ b !, f u med ,0r ,ndividua, pixe,s} - ^ oWain8d 'owresolution raster data are included 

.n the ccfrtrol arcurt command 3 and the resultant command is transmitted to the control circuit 5. The printer driver 1 
does not perform "color converse" and "halftoning" of the illustration data, which are high-resolution raster data of a 
22?f* T {speci Lf ,ly - ,u,, ™ tor RGB raster data for an 8-bit byte with which the color component of the 
individual pncels can express 256 tones). The high-resolution raster data are included in the control drcTcommand 3 
COmmand ' S transmitted to the control circuit 5. Therefore, the control circuit 5 performs "color coW 
sion and halftoning only for the photo RGB data. w»vw 

[0023] There are two main reasons that the printer driver 1 performs "color conversion" and "halftoning" for charac- 
ters/graphics, and the control circuit 5 performs such processing for the illustration: First, since the above process for 
< 5 * a h rarte ^9 ra P h,cs .9 en era»y does not impose a large load on the CPU but the process for the illustration does for 
45 high-speed proce.^mg the most effective procedure is for the heavy load process to be controlled and executed by the 
control circuit 5. which .s dedicated hardware, rather than the CPU. Second, although the character/graphic data must 
* Ji* r ^'° n b J ecause outlines ™st be printed clearly, compared to the quantity of the high-resolution fun- 
cole* RGB raster data, which .s enormous, the quantity of the high-resolution binary CMYK raster data is not very large 
so tha only a short penod of t.me is required to transfer the binary CMYK raster data from the printer driver i I to ttie 
so control circuit 5. 

[0024] As is shown in Fig. 1 the control circuit 5 comprises: host interface circuit 11. a command analysis/path control 
circuit 13 a color conversran/halftoning circuit 15, a superimposing/interlacing circuit 17. a memory control circuit 19 a 
memory 21, a command generator 23. and a printer interface circuit 25. The host interface circuit 1 1 receives a series 

* Jn ,nd,cated by an arrow I : ,ncluded in *e series of commands are various commands, such as a command for 
donating vanous print condrt.ons. a paper feeding command, a command for the transmission of the full-color RGB 
data for the photo, and a command for the transmission of the binary CMYK raster data for the characters/graphics In 
the following explanation, a command for transmitting full-color RGB raster data for a photo is called an RGB raster 
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command, a command for transmitting binary CMYK raster data for characters/graphics is called a CMYK raster com- 
mand, and the general term used to describe both of the commands is image data command. 
[0025] The command analysis/path control circuit 13 analyzes the received control circuit command 3, and extracts 
the command type. Basically, each command consists of a < command header ) and ( data ) . Command code that indi- 

5 cates the command type and predetermined parameters, as needed, are included in the command header field. Data 
that correspond to the command type are included in the data field; for example, the print condition contents of a com- 
mand for designating the print condition, binary CMYK raster data for characters/graphics for the CMYK raster com- 
mand, or full-color RGB raster data for a photo for the RGB raster command, it should be noted that there is one 
command with which there is no accompanying (data) . Upon receipt of the thus structured command, the command 

10 analysis^ath control circuit 13 identifies the command type from the (command header) . 

[0026] When a received command is an RGB raster command, the command analysis/path control circuit 13 trans- 
mits for an illustration full-color RGB raster data, which constitute the (data) in the command, to the color conver- 
sion/halftoning circuit 15 as indicated by an arrow 33. When a received command is a CMYK raster command, the 
command analysis/path control circuit 13 transmits binary CMYK raster data for a character/graphic, which constitute 

75 the (data) in the command, to the superimposing/interlacing circuit 1 7 as indicated by an arrow 35. When a received 
command is other than an image data command (e.g., a command for designating a printing condition, or a paper feed- 
ing command), based on the command, the command analysis/path control circuit 13 sets the individual sections of the 
control command 5, as needed, or, if the printer 9 must be notified of the contents of the command, transmits the com- 
mand to the superimposing/interlacing circuit 1 7, as is indicated by the arrow 35. 

20 [0027] When the command analysis^ath control circuit 1 3 receives a command that it can not identify, it transmits the 
command and all sequentially received information to the printer interface circuit 25, as is indicated by an arrow 37. It 
should be noted that such a case occurs when the printer driver 1 is an older version that is not compatible with the 
control circuit 5, and when a printer command that the control circuit 5 can not interpret is received. In this case, such 
a printer command is transmitted to the printer 9 via the printer interface circuit 25 (that is, a conventional process is 

25 performed for transmitting the printer command from the printer driver 1 to the printer 9). 

[0028] The color conversion/halftoning circuit 1 5 performs color conversion and halftoning processing for the full-color 
RGB raster data received for the illustration from the circuit 13 to convert the data to binary CMYK raster data, which 
are thereafter transmitted to the superimposing/interlacing circuit 17 as indicated by an arrow 39. 
[0029] As is described above, the superimposing/interlacing circuit 1 7 receives, from the command analysis/path con- 

30 trol circuit 13, a command (e.g., a command for designating a print condition, or a paper feeding command) other than 
an image command, and the binary CMYK raster data for characters/graphics, and receives the photo binary CMYK 
raster data from the color conversion/halftoning circuit 15. The superimposing/interlacing circuit 1 7 transmits a com- 
mand received from the command analysis/path control circuit 13 via the memory control circuit 19 and stores it in a 
command buffer 211 in the memory 21 as indicated by arrows 41 and 43. The superimposing/interlacing circuit 17 

35 transmits, via the memory control circuit 19, the binary CMYK raster data for characters/graphics received from the 
command analysis/path control circuit 13 and the photo binary CMYK raster data received from the color conver- 
sion/halftoning circuit 15. and stores them in an image buffer 213 in the memory 21 as indicated by arrows 41 and 43. 
Before storing the binary CMYK raster data for the photo and for the character/graphic in the memory 21 , the superim- 
posing/interlacing circuit 17 designates a data writing address to the memory control circuit 19 so that the photo data 

AO and the character/graphic data for a corresponding pixel position be written at the same address in the memory 21 . As 
a result, in the memory 21 are developed binary CMYK raster data for a complete image in which a photo image and a 
character/graphic image are superimposed (OR-operated). 

[0030] In addition, when storing in the memory 21 the commands and binary CMYK raster data that are received, the 
superimposing/interlacing circuit 17 memorizes the order in which the commands and image data are stored. The 

45 superimposing/interlacing circuit 17 reads the commands and the superimposed binary CMYK raster data from the 
memory 21 via the memory control circuit 19 as indicated by arrows 41 and 43, and transmits them to the command 
generation circuit 23 as indicated by an arrow 45. If so-called interlace printing or so-called overlap printing is to be per- 
formed, the superimposing/interlacing circuit 1 7 changes the order of pixels or thins them out for the interlace printing 
or the overlap printing before transmitting to the command generation circuit 23 the binary CMYK raster data read from 

so the memory 21. 

[0031 ] As is described above, upon receiving an instruction from the superimposing/interlacing circuit 1 7, the memory 
control circuit 19 writes to and reads from the memory 21 the commands and the binary CMYK raster data as indicated 
by the arrow 43. The memory 21 is used as a buffer for temporarily storing the commands and the binary CMYK raster 
data, and includes the command buffer area 21 1 for storing commands and the image buffer area 21 3 for storing CMYK 
55 raster data. Furthermore, although not shown, the memory 21 also includes an area for registering data required for the 
interlace printing and the overlap printing. 

[0032] The command generation circuit 23 receives, from the superimposing/interlacing circuit 17, the above 
described commands and the binary CMYK raster data for a complete image, converts the received data into a printer 
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command 47 that the printer 9 can understand, and transmits the printer command 47 to the printer interface circuit 25 
The printer interface circuit 25 transmits the printer command 47, which it receives from the command generation circuit 
23, to the pnrrter 9 Further, as described above, the printer interface circuit 25 also transmits the command from the 
command analysis/path control circuit 13 to the printer 9. The printer 9 then interprets the received printer command 7 
5 and performs the printing. u ' 

SIS. ^h* 16 a 5 )VB . de8C * ed an-angement, the printer driver 1 need only perform a light process for converting 
characters and graph.cs in an .mage to be printed into binary CMYK raster data, and the control circuit 5. which is pure 
hardware, performs a heavy process for converting a photo into binary CMYK raster data. Therefore, the host computer 
« not required to perform the heavy process. Furthermore, since the control circuit 5 superimposes the CMYK data for 
10 the characters/graph.cs and for the illustration to provide the complete image data, and transmits the data to the printer 
9 the printer S Ms also not required to perform complicated image processing. In addition, since at the first stage T char- 
acters or graphics that require a high resolution are converted by the printer driver 1 and the quantity of binary CMYK 
raster date that is thus obtained is not large, the time required for transferring data to the control circuit 5 at the following 
stage will not be extended. As a result, the last binary CMYK raster data can be quickly obtained, and high-speed print- 
ing is ensured. In addrtion. since ttie control circuit 5 using an ASIC can be manufactured at a low cost, the price of this 
sytfem is lower than a system employing a conventional high-speed printer in which is mounted a fast CPU 
[0034] An explanation will now be given for the arrangement for the superimposing/interlacing circuit 1 7 of the control 
rnn«, / ? ** mem0ry 21 « u P erim P°««l image data for the illustration and the characters/graphics 
[0035] As prev.ously described, the color conversion/halftoning circuit 15 transmits to the superimposirig/inter'lacina 

^ix^sss^ rr.T f K r *r i,iustration ' and the command cSisiss 

thereto the binary CMYK raster data for the characters/graphics. The circuits 1 5 and 13 output for each raster (for each 
line in the main image scanning direction) the binary CMYK raster data for the illustration and for the characters/graph- 
ic^ The superimposing/interlacing circuit 17 receives raster data from the circuit that transmitted them earlier i e 
either the color convers.on/halftoning circuit 15 or the command analysis/path control circuit 13 and writes the raster 
data ,n toe memory 21 During the writing of the raster data, the output of raster data from the other circuit is inhibited 
Then when tiie data for one raster that are received either from the first circuit 1 3 or 1 5 have been written in the memory 

fnni? 3 7 IT, 6 r T & Sre reCe ' Ved frt>m the < * er circuit and are superimposed and written in the memory 21 
[0036] Immediately 'after the color conversion/halftoning circuit 15 and the command analysis/path control circuit 13 
have output raster data for one raster, they output an <eor> command that indicates the end of a raster. For a raster for 
which there are no raster data to be output, the color conversion/halftoning circuit 15 and the command analysis/path 
control arcurt 13 output onty the <eor> command. When the superimposing/interlacing circuit 17 receives <eor> com- 
mands from both circuits 13 and 1 5, it ascertains that one raster has been completed 

[0037]^ The form of data slightly differs between the illustration raster data produced by the color conversfonmalftoning 
circuit 15 and the character/graphic raster data produced by the command analysis/path control circuit 1 3. As is shown 
n Fig. 3 in the.llustrat.on raster data, each byte 71 corresponds to a pixel (first PIC, second PIC. ...) in one raster and 
thefirst four bite, for exampte, of each byte 71 designate the CMYK element for the pixel. On the other hand, as issnown 
'"J' 9- ™! character/ 9 ra P nic raster data is divided into data strings 73 for individual CMYK colors, and each of the data 
strings 73 for individual CMYK colors consists of a color designation code 75 at the head and a succeeding bit string 
77 that represents the pertinent color elements of the individual pixels (first PIC, second PIC ) in one raster 
iS^f I T't 5 ^ MK . 3 segment of me superimposing/interlacing circuit 1 7 tor writing raster data in the memory 21 
[0039] In Fig. 5, as is described above, a raster completion check circuit 81 receives < eor> commands both from the 
color cowersion/hatftoning circuit 15 and from the command analysis/path control circuit 13. and then generates a 
raster completion signal and transmits it to an address determination circuit 87, which will be described later A format 
conversion circuit 82 receives from the color conversion/halftoning circuit 15 illustration raster data having the pixel for- 
mat shown in Fig. 3. and stores in internal shift registers (not shown) the CMYK color bits for the individual CMYK colors 
that are .ncluded iri the pixel data that are received. When data for one word (e.g.. 16 bits) have been accumulated in 
he shift registers, for an individual color a word equivalent to 1 6 pixels is extracted from the shift registers and is written 
to an illustration raster data processing circuit 83. At this time, words are written separately by color, for example in the 
following order: a word for color C. a word for color M and a word for color Y. The illustration raster data processing cir- 
cuit 83 receives from the format conversion circuit 82 the illustration raster data whose format has been converted into 
individual color words as described above, and upon each reception of a color word generates a color count signal that 
it transmits to the address determination circuit 87. Also, the illustration raster data circuit 83 outputs as write data to 
the memory control circuit 1 9 the words that are received, and generates a pixel count signal for each bit in each word 
and transmrts the signal to the address determination circuit 87. A character/graphic raster data processing circuit 85 
receives from the command analysis/path control circuit 13 the character/graphic raster data having the format shown 
in Fig. 4. and upon each reception of a color designation code 75 in a color data string 73 generates a color count sianal 
that rt transmits to the address determination circuit 87. Further, upon receiving the individual bits in the succeeding bit 
stnng 77. the character/graphic raster data processing circuit 85 transmits these bits as write data to the memory con- 
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trol circuit 19, and generates a pixel count signal that it transmits to the address determination circuit 87. ft should be 
noted that one or the other of the illustration raster data processing circuit 83 and the character/graphic raster data 
processing circuit 85 is being operated at all times, and that the circuits 83 and 85 are not operated at the same time. 
[0040] The address determination circuit 87, which has the arrangement shown in Fig. 6. determines at which 

5 address in the image buffer area 213 of the memory 21 data is to be written. 

[0041 ] Before the explanation is given for the arrangement of the address determination circuit 87 in Fig. 6. the struc- 
ture of the image buffer area 213 of the memory 21 will be explained while referring to Fig. 7. As is shown in Fig. 7, the 
image buffer area 21 3 of the memory 21 is divided into a C plane 1 1 1 C. an M plane 1 1 1 M, a Y plane 1 1 1 Y, and a K 
plane 1 1 1 K. The data for color elements for N rasters can be stored in the corresponding color planes 1 1 1 C to 1 1 1K 

w (the determination method for N will be described later). A head address is assigned for each of the color planes 1 1 1C 
to-,1 1 1 K so that the planes do not overlap each other. When the first raster in each color plane. 1 1 1 C to 1 1 1 K is regarded 
as number 0, the numbers provided for individual rasters are called "vertical addresses," and when the first pixel (first 
PIC) in each raster is regarded as number 0, the numbers provided for the individual pixels are called "horizontal 
addresses." Therefore, an absolute address for each plane in the image buffer area 213 is defined as a set composed 

is of a head address, a vertical address, and a horizontal address. 

[0042] As is shown in Fig. 6, the address determination circuit 87 has three types of counters: a vertical address coun- 
ter 91 , a horizontal address counter 1 03, and a color selection counter 1 01 . The vertical address counter 91 generates 
the above described vertical address, and increments the vertical address by one each time a raster completion signal 
is received from the raster completion check circuit 81 in Fig.5. The horizontal address counter 103 generates the 

20 above described horizontal address, and increments the horizontal address by one each time a pixel count signal is 
received from the raster data processing circuits 83 and 85 in Fig.5. The horizontal address counter 1 03 is initialized by 
the above described raster completion signal. The color selection counter 101 generates a color selection signal to 
select one of the four color planes in Fig 4. and switches color selection signals upon receiving a color count signal from 
the raster data processing circuit 83 or 85 in Fig. 5. The color selection signal is transmitted to a selector 105. 

25 [0043] The selector 1 05 is connected to four head address registers 93 to 99 in which the head addresses for the C, 
M. Y and K planes 1 1 1 C to 1 1 1 K are held. Upon receiving a color selection signal from the color selection counter 101, 
the selector 105 selects one of the four head address registers 93 to 99. and reads the head address from the selected 
head address register and outputs it. A synthesization circuit 107 generates a write address by combining the color 
plane head address received from the selector 105, the vertical address received from the vertical address counter 91 

30 and the horizontal address received from the horizontal address counter 103, and registers it in a write address register 
109. The write address that is registered in the write address register 109 is transmitted to the memory control circuit 
19. The memory control circuit 1 09 writes, at the write address in the memory 21 , the write data that are received from 
the raster data processing circuits 83 to 85 in Fig.5. This writing process is effected by using new data to OR the data 
that are already present at the address. 

35 [0044] The thus arranged address determination circuit 87 designates the same write address for data for the same 
pixel, regardless of whether an image is an illustration or characters/graphics. Therefore, the raster data for a complete 
image obtained by superimposing the illustration and the characters/graphics are developed in the memory 21. 
Although the formats for the data for the illustration and the characters/graphics differ, as is shown in Figs. 3 and 4, the 
write address for both types of data is determined not by separate circuits but by the common address determination 

40 circuit 87, and a simplified and inexpensive control circuit 5 can be provided. For a raster for which there are no image 
data, only the <eor) commands are transferred, with no accompanying image data, and the vertical address is incre- 
mented by the two (eor> commands. Therefore, the same operation can be performed as is performed when writing 
null data in the memory 21 without actually accessing the memory 21, and this contributes to an increase in the 
processing speed. 

45 [0045] The raster line ring buffer method can be used as the method for storing data in the image buffer area 213 in 
the memory 21 . The capacity of the image buffer area 213 that is required for the ring buffer method is: 

buffer capacity = N x the number of colors x horizontal resolution x paper width. 

so The number of colors is the number of coloring agents used by a printer, and in this embodiment, the four colors CMYK 
are employed. However, some printers have six or seven colors because light and heavy coloring agents are employed. 
The horizontal resolution is the raster data resolution in the horizontal direction (= main scanning direction or head 
scanning direction), and the paper width is the horizontal length of a printing sheet (measured by dots). The maximum 
value for the system is employed for the resolution and the paper size. N is the number of rasters that are required to 

55 be stored in the memory. Hereinafter a memory area in which data for one raster can be stored is regarded as one unit, 
and this unit is called a memory index. Therefore, N is the number of memory indexes in the image buffer area 213 in 
the memory 21, and 
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N = (nozzle count - 1) x path count + 1 + interlace paper feeding distance 

mmmmm 

S5S ° P Wntin9/readin9 raster data in or from « h « memory 21 will now be described while referring to 

^IL!?r i9 " f 3 ? raSterS th3t are printed a,on9 the individual P^hs (head scans) when the nozzle count - 

[0049] Following this, data are read for the second path as is shown in a table 133 For this processina the rad 
SS ^ 9thT 3 ^"l7th^nd'^i Z h '- e - ^ 6th ' 10th ' 14th ' 18th and 22nd rasters - are sequentially read ftoTte 

M «m nm, data a„ ,aad fa, th, fta, raaers tat .a,** to We „„j palh i s ma 1 m TahTII? 

iSimrrr^T" 1 of . the , present invention been explained, but the present invention is not limited to this 
S r e Jl a ? ™£ Var '° USly m0dified departin 9 fro™ the scope of the invention. In the 

mand for transm.ss.on to the pnnter. However, image data may be exchanged with the host computer * 
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a more direct method without employing a command. For example, a host computer incorporating a control circuit may 
directly receive image data for illustrations or for characters/graphics via the CPU bus of the host computer. And the 
printer-incorporating control circuit may transfer, directly to the print head of the printer, image data that are obtained by 
superimposing illustrations and characters/graphics. 

5 

Claims 

1 . A printer control circuit, which is a dedicated printer control hardware circuit disposed between an upper apparatus 
and a printer, comprising: 

w 

a halftoning circuit for performing a halftone process to convert high-resolution raster data, for a first image ele- 
ment, that are transmitted from said upper apparatus into first low-resolution raster data; and 
an image completion circuit for obtaining low-resolution raster data for a complete print image employing sec- 
* ond low-resolution raster data, for a second image element, that are transmitted from said upper apparatus, 
75 : ■ and said first low-resolution raster data, for said first image element, that are transmitted from said halftoning 
circuit. 

2. A printer control circuit according to claim 1 , wherein said first image element is an illustration, and said second 
image element constitutes characters and graphics. 

20 

3. A printer control circuit according to claim 1 or 2, wherein said high-resolution raster data for said first image ele- 
ment, which are transmitted from said upper apparatus, are expressed using an upper apparatus display color-sys- 
tem that differs from a printer display color system that is employed by said printer; wherein said second low- 
resolution raster data for said second image element, which are transmitted from said upper apparatus, are 

25 expressed using said printer display color system; and wherein said halftoning circuit also performs color conver- 
sion for said high-resolution raster data for said f irst image element that are transmitted from said upper apparatus 
display color system to said printer display color system. 

4. A printer control circuit according to claim 1, wherein for said low-resolution raster data for said complete print 
30 image said image completion circuit changes pixel order for interlaced printing. 

& A printer control apparatus according to claim 1 , wherein a memory is provided for said image completion circuit. 

•~ and wherein to obtain said low-resolution raster data for said complete print image said first low-resolution raster 

v data for said first image element and said second low-resolution raster data for said second image element are 

35 superimposed and are written in said memory. 

6. A printer control apparatus according to claim 5, wherein, when said image completion circuit is writing one of said 
first low-resolution raster data for said first image element and said second low-resolution raster data for said sec- 
ond image element, said image completion circuit holds the other of said first and second low-resolution raster 

40 image data that are to be written to said memory. 

7. A printer control apparatus according to claim 5, wherein said high-resolution raster data for said first image ele- 
ment and said second low-resolution raster data for said second image element are sequentially transmitted by 
said upper apparatus; and wherein, when said image completion circuit recognizes that raster data both for said 

45 first and for said second image elements have been rasterized, said image completion circuit increments a vertical 
address for designating a location in said memory for writing said raster data, and superimposes and writes, at the 
same vertical address in said memory, said raster data for said first and said second image elements for the same 
raster. 

so 8. A printer control apparatus according to claim 7, wherein, for a raster having said first image element or said sec- 
ond element not available, a raster end command for instructing raster termination of a pertinent image element is 
transmitted by said upper apparatus, and wherein, upon receiving said raster end command, said image comple- 
tion circuit acknowledges said raster termination of said pertinent image element and obtains the same results 
without requiring null data for said pertinent image element that is being written in said memory. 

55 

9. A printer control apparatus according to claim 5, wherein, in order to develop said low-resolution raster data for said 
complete print image, said memory has a capacity that is large enough to store all the raster data in a range that 
is equivalent to one where the print head of said printer covers two paths; and wherein, while said image comple- 
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s 1 0. A printer control apparatus according to claim 5, wherein said image completion circuit writes raster data to 
a^S^ a ? d " ,d ^-circuit 4ds^^ 

S2TS^ £2g$£ Cyde ^ ^ ^ h * — 1 — "«* * -ding ^de 

11. A printer comprising: 

^™ 

a halftoning circuit for performing halftoning for high-resolution raster data for a first image element rah** 
from sa.d upper apparatus and obtaining first low-resolution raster data- and 

an imapa completion circuit for obtaining low-resolution raster data for a complete print image from second low 

14 " i Pnn . te « aCC ° rdi !! 9 1° C ' aim 1 1 ' Wh6rein for ^ tow-resolution raster data for said complete print image said imaae 
completion circuit changes pixel order for interlaced printing. 9 9 

1S " iSn«H < f° rdin9 f° rf C,aim 11 ' Wherein 3 memory is P rovided for image completion circuit and wherein to 
obtain sard low-resolut.on raster data for said complete print image said first low-resolution raster data InZ Z f £ 

r w e ^n^ 

1 6 ' in^ZaT^u^ W t hen H said ! ma 9 e circuit is writing one of said first .ow-resolu- 

xion raster oata for said first image element and said second low-resolution raster data for said second imar™ B il 

1 7 " tSUT aC °? r f na to daim 1S - wherein high-resolution raster data for said first image element and said sec- 
and whl ^ h n raSt J da{ " ' VSaid SeC ° nd ima9e element are sequentially transmitted by saTupperlp^t 
Trnfof r ^ ! n *? ' ma9e circurt re ~9n«es that raster data both for said first arriTsaSTe^nd 

T£2£ , raS,eriZed ' ^ ima9e comp,etion circuit cerements a vertical «£Z fordesiaSna 

Tn m 10 m r° ry ^ Writi " 9 ^ raStef data ' and ^Perimposes and writes, at lh,^^J£uS22 
.n said memory. sa,d raster data for said first and said second image elements for the same ^r 

18 ' tSlSSi T^ST* 17 ' W , he, : ein - ,or a raster "* "«-Q» element or said second e.ement not 

Sfd^pe 9 STSSS ' nStrUCtin9 ^ termhati ° n ° f 3 P6rtinent ima9e element is transmitlX 

^Tn^l ^ ■ ^ recemn 9 said raster end command, said image completion circuit 

acknowledges said raster termination of said pertinent image element and obtains the same resuSSSSl ZT 
ing null data for said pertinent image element that is being written in said memory 
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19. A printer according to claim 15, wherein, in order to develop said low-resolution raster data for said complete print 
image, said memory has a capacity that is large enough to store all the raster data in a range that is equivalent to 
one where the print head of said printer covers two paths; and wherein, while said image completion circuit reads 
raster data stored in said memory that said print head requires for the current path, said image completion circuit 

5 writes raster data in said memory until the last raster that said print head requires for the next path is reached. 

20. A printer according to claim 15, wherein said image completion circuit writes raster data to said memory in an OR 
write mode; and wherein said image completion circuit reads raster mode from said memory in a clear read mode 
during the last reading cycle for each raster, and in a normal read mode during reading cycle other than the last 

10 reading cycle. 

21. A printing system comprising: 

an upper apparatus; 
75 a printer; and 

a dedicated printer control hardware circuit located in between said upper apparatus and said printer, 
said dedicated hardware circuit including 

a halftoning circuit for performing halftoning for high-resolution raster data for a first image element received 
from said upper apparatus and obtaining f irst low-resolution raster data, and 
20 an image completion circuit for obtaining low-resolution raster data for a complete print image from second low- 

resolution raster data that are received from said upper apparatus for a second image element, and said first 
low-resolution raster data that are received from said halftoning circuit for said first image element 

22. A printing system according to claim 21, wherein said first image element is an illustration, and said second image 
25 element constitutes characters and graphics. 

23. A printing system according to claim 21 or 22, wherein said high-resolution raster data for said first image element, 
which are transmitted from said upper apparatus, are expressed using an upper apparatus display color system 
that differs from a printer display color system that is employed by said printer; wherein said second low-resolution 

30 raster data for said second image element, which are transmitted from said upper apparatus, are expressed using 
said printer display color system; and wherein said halftoning circuit also performs color conversion for said high- 
resolution raster data for said first image element that are transmitted from said upper apparatus display color sys- 
tem to said printer display color system. 

35 24. A printing system according to claim 21, wherein for said low-resolution raster data for said complete print image 
said image completion circuit changes pixel order for interlaced printing. 

25. A printing system according to claim 21, wherein a memory is provided for said image completion circuit and 
wherein to obtain said low-resolution raster data for said complete print image said first low-resolution raster data 

40 for said first image element and said second low-resolution raster data for said second image element are super- 
imposed and are written in said memory. 

26. An upper apparatus, for a printing system for outputting image data to be printed by a printer, that outputs high-res- 
olution raster data for a first image element included in a print image and low-resolution raster data for which haff- 

45 toning has been processed for a second image element included in said print image. 

27. An upper apparatus according to claim 26, wherein said first image element is an illustration, and said second 
image element constitutes characters and graphics. 

so 28. An upper apparatus according to claim 26, which expresses said high-resolution raster data for said first image ele- 
ment using an upper apparatus display color system that differs from a printer cfisplay color system that is employed 
by said printer, and which expresses said low-resolution raster data for said second image element using said 
printer display color system. 

55 29. An upper apparatus according to claim 26, which sequentially transmits said high-resolution raster image for said 
first image element and said low-resolution raster data for said second image element, and which, for a raster hav- 
ing said first image element or said second image element not available, transmits a raster end command for 
instructing raster termination of a pertinent image element. 
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30. A computer-readable recording medium on which is stored a computer program for use in a computer said com- 

SE^S^X"; Wr . aP Sm* ^ 8 Prin,in9 SySt6m for 0UtpUtfin 9 ' ^ data to be PrintedCpSerThat 
outputs Jgh-resoluton raster data for a first image element included in a print image and low-resolution raste -data 
for wh.ch halftoning has been processed for a second image element included in Lid print image 
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FIG. 2 
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FIG. 8 
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(57) To provide high-speed printing with an inexpen- 
sive arrangement, a dedicated printer control hardware 
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computer and a printer 9. The printer driver 1 divides an 
image to be printed into an illustration (a natural image), 
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graphics. The printer driver outputs full-color RGB raster 
data for the illustration, while performing color conver- 
sion/halftoning for the character/graphic data and out- 



putting binary CMYK raster data. The control circuit 5 
performs color conversion/halftoning for the full-color il- 
lustration RGB raster data to convert them into binary 
CMYK raster data. Then, the control circuit 5 superim- 
poses the obtained binary CMYK raster data and the 
binary CMYK raster data for characters/graphics to form 
binary CMYK raster data for a complete print image, and 
transmits the final binary CMYK raster data to the printer 
9. The control circuit 5 also rearranges or thins pixel data 
for interlace printing or overlap printing. 
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